import Vue from 'vue'

import 'normalize.css/normalize.css' // A modern alternative to CSS resets

import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
import locale from 'element-ui/lib/locale/lang/en' // lang i18n

import '@/styles/index.scss' // global css

import App from './App'
import store from './store'
import router from './router'

import '@/icons' // icon
import '@/permission' // permission control

// set ElementUI lang to EN
Vue.use(ElementUI, { locale })
// 如果想要中文版 element-ui，按如下方式声明
// Vue.use(ElementUI)

// 引入自定义指令
import { imgerr } from './directives/index'
// 自定义指令
Vue.directive('imgerr', imgerr)

// 全局注册PageTools组件
import myComponents from '@/components'
Vue.use(myComponents)

// 一次性引入大量过滤器
import * as filters from '@/filters'

for (const key in filters) {
  const name = key
  const fn = filters[key]
  Vue.filter(name, fn)
}

// 注入mixin
import mixinObj from '@/mixin'
Vue.mixin(mixinObj)

Vue.config.productionTip = false

new Vue({
  el: '#app',
  router,
  store,
  render: h => h(App)
})
